## 2024 Digital IC Design

## Homework 4: Max-Priority Queue

| NAME                              |     |           |                      |          |                                                     |                                   |                                  |                                                                  |
|-----------------------------------|-----|-----------|----------------------|----------|-----------------------------------------------------|-----------------------------------|----------------------------------|------------------------------------------------------------------|
| Student II                        |     | E34106010 |                      |          |                                                     |                                   |                                  |                                                                  |
| Simulation Result                 |     |           |                      |          |                                                     |                                   |                                  |                                                                  |
| Functional simulation             | 100 | )         | te-level<br>aulation | 100      | Clock                                               | 17 ns                             | Gate-level<br>simulation<br>time | P0:1269.271ns<br>P1:1643.271ns<br>P2:1779.271ns<br>P3:2204.271ns |
| # *** *** Congratulations !! ***  |     |           |                      |          | # *** Congratulations !!                            |                                   |                                  |                                                                  |
|                                   |     |           |                      | Synthesi | is Resu                                             | lt                                |                                  |                                                                  |
| Total logic elements              |     |           |                      |          | 761                                                 |                                   |                                  |                                                                  |
| Total memory bit                  |     |           |                      |          | 0                                                   |                                   |                                  |                                                                  |
| Embedded multiplier 9-bit element |     |           |                      |          | 0                                                   |                                   |                                  |                                                                  |
| Flow Status Successful - S        |     |           |                      |          | Sun May 26 15<br>220 11/11/202<br>A7<br>(1 %)<br>%) | 0:04:45 2024<br>200 SJ Lite Editi | on                               |                                                                  |

## **Description of your design**

Idx register:此值代表正在處理的 element 在陣列中的位置。

Size register:為陣列中最後一個 valid element 所在的位置。

INPUT:直接將資料輸入進陣列中,輸入完再進行 Heapify,Heapify 我將其分成三個 state,HEAPIFY、EXCHANGE\_WITH\_LARGEST、

NEXT\_HEAPIFY,在 HEAPIFY 時將比較 left child 和 right child 哪個是較大的,EXCHANGE\_WITH\_LARGEST 時將現在的 idx 跟 largest 者進行交換,NEXT HEAPIFY 判斷還有沒有下次 HEAPIFY。

EXTRACT\_MAX:將最後的元素擺到第一個位置上,並將狀態接到 HEAPIFY 上。

INCREASE:一路往 parent 比較,若現在的 idx 較大則跟 parent 做交換。

WRITE:透過 WRITE\_DELAY 來穩定確認資料有正確讀到後,下一個 state 接到 WRITE 上將 RAM VALID 拉起進行輸出。

 $Scoring = (Total\ logic\ elements + total\ memory\ bit + 9*embedded\ multiplier\ 9-bit\ element) \times (Total\ cycle\ used*clock\ width)$